<template>
  <!-- 主体部分 -->
  <section class="main">
    <input 
      id="toggle-all" 
      class="toggle-all" 
      type="checkbox" 
      
      @change="changeAllFlag"
    />
    <label for="toggle-all">Mark all as complete</label>
    <ul class="todo-list">
      <!-- 当任务已完成，可以给 li 加上 completed 类，会让元素加上删除线 -->
      <li 
        :class="{completed: item.flag}" 
        v-for="item in list" 
        :key="item.id"
      >
        <div class="view">
          <input 
            class="toggle" 
            type="checkbox" 
            
            :checked="item.flag" 
            @change="changeFlag(item.id, $event)"
          />
          <label>{{ item.value }}</label>
          <button class="destroy" @click="delList(item.id)"></button>
        </div>
      </li>
    </ul>
  </section>
</template>

<script>
export default {
  name: 'TodoListBody',

  props: {
    list: {
      type: Array,
      required: true
    }
  },
  data() {
    return {}
  },

  methods: {
    // 请求改变事件状态
    changeFlag(id,e) {
      this.$emit('changeFlag', id, e.target.checked)
    },

    // 请求删除事件
    delList(id) {
      this.$emit('delList', id)
    },

    // 请求改变全部事件为完成
    changeAllFlag() {
      this.$emit('changeAllFlag')
    }
  },
}
</script>

<style scoped></style>
